import Mock from 'mockjs'

const List = []
const count = 100

const baseContent = '<p>I am testing data, I am testing data.</p><p><img src="https://wpimg.wallstcn.com/4c69009c-0fd4-4153-b112-6cb53d1cf943"></p>'
const image_uri = 'https://wpimg.wallstcn.com/e4558086-631c-425c-9430-56ffb46e70b3'

for (let i = 0; i < count; i++) {
    List.push(Mock.mock({
        id: '@increment',
        author: "@Random.first()",
        eqName: +Mock.Random.date('T'),
        'eqCode|1': ["龙应台", "朱自清", "海子"],
        'eqNum|1': ["龙应台", "朱自清", "海子"],
        'eqCategory|1': ["桌子", "椅子", "起重机"],
        'eqKind|1': ["常用设备", "非常用设备"],
        'eqDepartment|1': ["科技部", "制造部", "工业部"],
        eqManager: '@Random.first()',
        eqUseDay: '@Random.date()',
        'eqOriginNum|1': ['CN', 'US', 'JP', 'EU'],
        'eqStatus|1': ['published', ' ', 'deleted'],
        eqCreateTime: '@datetime',
        'eqStatus|1': '@integer(1,3)',
        eqText: '@integer(300, 5000)',
        timestamp: +Mock.Random.date('T'),
        'author|1': ["龙应台", "朱自清", "海子"],
        'reviewer|1': ["龙应台", "朱自清", "海子"],
        'title|1': ["桌子", "椅子", "起重机"],
        content_short: 'mock data',
        content: baseContent,
        forecast: '@float(0, 100, 2, 2)',
        importance: '@integer(1, 3)',
        'type|1': ['CN', 'US', 'JP', 'EU'],
        'status|1': ['published', ' ', 'deleted'],
        display_time: '@datetime',
        comment_disabled: true,
        pageviews: '@integer(300, 5000)',
        image_uri,
        platforms: ['a-platform']
    }))
}

export default [{
        url: '/article/list',
        type: 'get',
        response: config => {
            const { importance, type, title, page = 1, limit = 20, sort } = config.query

            let mockList = List.filter(item => {
                if (importance && item.importance !== +importance) return false
                if (type && item.type !== type) return false
                if (title && item.title.indexOf(title) < 0) return false
                return true
            })

            if (sort === '-id') {
                mockList = mockList.reverse()
            }

            const pageList = mockList.filter((item, index) => index < limit * page && index >= limit * (page - 1))

            return {
                code: 20000,
                data: {
                    total: mockList.length,
                    items: pageList
                }
            }
        }
    },

    {
        url: '/article/detail',
        type: 'get',
        response: config => {
            const { id } = config.query
            for (const article of List) {
                if (article.id === +id) {
                    return {
                        code: 20000,
                        data: article
                    }
                }
            }
        }
    },

    {
        url: '/article/pv',
        type: 'get',
        response: _ => {
            return {
                code: 20000,
                data: {
                    pvData: [
                        { key: 'PC', pv: 1024 },
                        { key: 'mobile', pv: 1024 },
                        { key: 'ios', pv: 1024 },
                        { key: 'android', pv: 1024 }
                    ]
                }
            }
        }
    },

    {
        url: '/article/create',
        type: 'post',
        response: _ => {
            return {
                code: 20000,
                data: 'success'
            }
        }
    },

    {
        url: '/article/update',
        type: 'post',
        response: _ => {
            return {
                code: 20000,
                data: 'success'
            }
        }
    }
]